<!DOCTYPE HTML>
<html lang="zh-hans" >
    
    <head>
        
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <title>5.配置用户身份验证 | Apache Drill</title>
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <meta name="description" content="">
        <meta name="generator" content="GitBook 2.6.6">
        <meta name="author" content="smartloli">
        
        <meta name="HandheldFriendly" content="true"/>
        <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
        <meta name="apple-mobile-web-app-capable" content="yes">
        <meta name="apple-mobile-web-app-status-bar-style" content="black">
        <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png">
        <link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon">
        
    <link rel="stylesheet" href="../gitbook/style.css">
    
        
        <link rel="stylesheet" href="../gitbook/plugins/gitbook-plugin-tbfed-pagefooter/footer.css">
        
    
        
        <link rel="stylesheet" href="../gitbook/plugins/gitbook-plugin-highlight/website.css">
        
    
        
        <link rel="stylesheet" href="../gitbook/plugins/gitbook-plugin-fontsettings/website.css">
        
    
    

        
    
    
    <link rel="next" href="../5.配置 Drill/6.配置 Hive 用户身份验证.html" />
    
    
    <link rel="prev" href="../5.配置 Drill/4.配置模拟身份.html" />
    

        
    </head>
    <body>
        
        
    <div class="book"
        data-level="5.5"
        data-chapter-title="5.配置用户身份验证"
        data-filepath="5.配置 Drill/5.配置用户身份验证.md"
        data-basepath=".."
        data-revision="Fri Aug 26 2016 12:40:11 GMT+0800 (CST)"
        data-innerlanguage="">
    

<div class="book-summary">
    <nav role="navigation">
        <ul class="summary">
            
            
            
                
                <li>
                    <a href="http://drill.smartloli.org" target="blank" class="custom-link">Apache Drill</a>
                </li>
            
            

            
            <li class="divider"></li>
            

            
    
        <li class="chapter " data-level="0" data-path="index.html">
            
                
                    <a href="../index.html">
                
                        <i class="fa fa-check"></i>
                        
                        前言
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="1" >
            
            <span><b>1.</b> 1.开始</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.1" data-path="1.开始/1.Introduction 介绍.html">
            
                
                    <a href="../1.开始/1.Introduction 介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>1.1.</b>
                        
                        1.Introduction 介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="1.开始/2.Why Drill 为什么使用 Drill.html">
            
                
                    <a href="../1.开始/2.Why Drill 为什么使用 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>1.2.</b>
                        
                        2.Why Drill 为什么使用 Drill
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="2" >
            
            <span><b>2.</b> 2.架构</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="2.1" data-path="2.架构/1.Architecture Introduction 架构介绍.html">
            
                
                    <a href="../2.架构/1.Architecture Introduction 架构介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>2.1.</b>
                        
                        1.Architecture Introduction 架构介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="2.2" data-path="2.架构/2.Drill Query Execution Drill 查询执行.html">
            
                
                    <a href="../2.架构/2.Drill Query Execution Drill 查询执行.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>2.2.</b>
                        
                        2.Drill Query Execution Drill 查询执行
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="2.3" data-path="2.架构/3.Core Modules 核心模块.html">
            
                
                    <a href="../2.架构/3.Core Modules 核心模块.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>2.3.</b>
                        
                        3.Core Modules 核心模块
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="2.4" data-path="2.架构/4.Performance 性能.html">
            
                
                    <a href="../2.架构/4.Performance 性能.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>2.4.</b>
                        
                        4.Performance 性能
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3" >
            
            <span><b>3.</b> 3.教程</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.1" data-path="3.教程/1.Tutorials Introduction 教程介绍.html">
            
                
                    <a href="../3.教程/1.Tutorials Introduction 教程介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.1.</b>
                        
                        1.Tutorials Introduction 教程介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.2" data-path="3.教程/2.Drill in 10 Minutes 快速指导.html">
            
                
                    <a href="../3.教程/2.Drill in 10 Minutes 快速指导.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.2.</b>
                        
                        2.Drill in 10 Minutes 快速指导
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.3" data-path="3.教程/3.A-Y-A-D 数据集分析.html">
            
                
                    <a href="../3.教程/3.A-Y-A-D 数据集分析.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.3.</b>
                        
                        3.A-Y-A-D 数据集分析
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.4" >
            
            <span><b>3.4.</b> 4.在 MapR 的 Sandbox 中学习 Drill</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="3.4.1" data-path="3.教程/4.在 MapR 的 Sandbox 中学习 Drill/1.关于 MapR 的 Sandbox.html">
            
                
                    <a href="../3.教程/4.在 MapR 的 Sandbox 中学习 Drill/1.关于 MapR 的 Sandbox.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.4.1.</b>
                        
                        1.关于 MapR 的 Sandbox
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.4.2" data-path="3.教程/4.在 MapR 的 Sandbox 中学习 Drill/2.在 Sandbox 中安装 Drill.html">
            
                
                    <a href="../3.教程/4.在 MapR 的 Sandbox 中学习 Drill/2.在 Sandbox 中安装 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.4.2.</b>
                        
                        2.在 Sandbox 中安装 Drill
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.4.3" data-path="3.教程/4.在 MapR 的 Sandbox 中学习 Drill/3.在 Sandbox 中使用 Drill.html">
            
                
                    <a href="../3.教程/4.在 MapR 的 Sandbox 中学习 Drill/3.在 Sandbox 中使用 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.4.3.</b>
                        
                        3.在 Sandbox 中使用 Drill
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.4.4" data-path="3.教程/4.在 MapR 的 Sandbox 中学习 Drill/4.课程1:学习数据集.html">
            
                
                    <a href="../3.教程/4.在 MapR 的 Sandbox 中学习 Drill/4.课程1:学习数据集.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.4.4.</b>
                        
                        4.课程1:学习数据集
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.4.5" data-path="3.教程/4.在 MapR 的 Sandbox 中学习 Drill/5.课程2:使用 ANSI SQL 查询.html">
            
                
                    <a href="../3.教程/4.在 MapR 的 Sandbox 中学习 Drill/5.课程2:使用 ANSI SQL 查询.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.4.5.</b>
                        
                        5.课程2:使用 ANSI SQL 查询
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.4.6" data-path="3.教程/4.在 MapR 的 Sandbox 中学习 Drill/6.课程3:查询复杂的数据类型.html">
            
                
                    <a href="../3.教程/4.在 MapR 的 Sandbox 中学习 Drill/6.课程3:查询复杂的数据类型.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.4.6.</b>
                        
                        6.课程3:查询复杂的数据类型
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.4.7" data-path="3.教程/4.在 MapR 的 Sandbox 中学习 Drill/7.总结.html">
            
                
                    <a href="../3.教程/4.在 MapR 的 Sandbox 中学习 Drill/7.总结.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.4.7.</b>
                        
                        7.总结
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="3.5" data-path="3.教程/5.高度动态的数据集分析.html">
            
                
                    <a href="../3.教程/5.高度动态的数据集分析.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.5.</b>
                        
                        5.高度动态的数据集分析
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.6" data-path="3.教程/6.社会媒体分析.html">
            
                
                    <a href="../3.教程/6.社会媒体分析.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.6.</b>
                        
                        6.社会媒体分析
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="3.7" data-path="3.教程/7.使用窗口函数分析数据.html">
            
                
                    <a href="../3.教程/7.使用窗口函数分析数据.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>3.7.</b>
                        
                        7.使用窗口函数分析数据
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4" >
            
            <span><b>4.</b> 4.安装 Drill</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.1" data-path="4.安装 Drill/1.Drill 安装介绍.html">
            
                
                    <a href="../4.安装 Drill/1.Drill 安装介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.1.</b>
                        
                        1.Drill 安装介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.2" data-path="4.安装 Drill/2.迁移 Parquet 数据.html">
            
                
                    <a href="../4.安装 Drill/2.迁移 Parquet 数据.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.2.</b>
                        
                        2.迁移 Parquet 数据
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.3" >
            
            <span><b>4.3.</b> 3.安装 Drill 到嵌入模式</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.3.1" data-path="4.安装 Drill/3.安装 Drill 到嵌入模式/1.嵌入模式的先决条件.html">
            
                
                    <a href="../4.安装 Drill/3.安装 Drill 到嵌入模式/1.嵌入模式的先决条件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.3.1.</b>
                        
                        1.嵌入模式的先决条件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.3.2" data-path="4.安装 Drill/3.安装 Drill 到嵌入模式/2.在 Linux 和 Mac OS X 上安装 Drill.html">
            
                
                    <a href="../4.安装 Drill/3.安装 Drill 到嵌入模式/2.在 Linux 和 Mac OS X 上安装 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.3.2.</b>
                        
                        2.在 Linux 和 Mac OS X 上安装 Drill
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.3.3" data-path="4.安装 Drill/3.安装 Drill 到嵌入模式/3.在 Linux 和 Mac OS X 上启动 Drill.html">
            
                
                    <a href="../4.安装 Drill/3.安装 Drill 到嵌入模式/3.在 Linux 和 Mac OS X 上启动 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.3.3.</b>
                        
                        3.在 Linux 和 Mac OS X 上启动 Drill
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.3.4" data-path="4.安装 Drill/3.安装 Drill 到嵌入模式/4.在 Windows 上安装 Drill.html">
            
                
                    <a href="../4.安装 Drill/3.安装 Drill 到嵌入模式/4.在 Windows 上安装 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.3.4.</b>
                        
                        4.在 Windows 上安装 Drill
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.3.5" data-path="4.安装 Drill/3.安装 Drill 到嵌入模式/5.在 Windows 上启动 Drill.html">
            
                
                    <a href="../4.安装 Drill/3.安装 Drill 到嵌入模式/5.在 Windows 上启动 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.3.5.</b>
                        
                        5.在 Windows 上启动 Drill
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4.4" >
            
            <span><b>4.4.</b> 4.安装 Drill 到分布式模式</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="4.4.1" data-path="4.安装 Drill/4.安装 Drill 到分布式模式/1.分布式模式的先决条件.html">
            
                
                    <a href="../4.安装 Drill/4.安装 Drill 到分布式模式/1.分布式模式的先决条件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.4.1.</b>
                        
                        1.分布式模式的先决条件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.4.2" data-path="4.安装 Drill/4.安装 Drill 到分布式模式/2.在集群上安装 Drill.html">
            
                
                    <a href="../4.安装 Drill/4.安装 Drill 到分布式模式/2.在集群上安装 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.4.2.</b>
                        
                        2.在集群上安装 Drill
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="4.4.3" data-path="4.安装 Drill/4.安装 Drill 到分布式模式/3.在分布式模式下启动 Drill.html">
            
                
                    <a href="../4.安装 Drill/4.安装 Drill 到分布式模式/3.在分布式模式下启动 Drill.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.4.3.</b>
                        
                        3.在分布式模式下启动 Drill
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="4.5" data-path="4.安装 Drill/5.启动 Web 控制台.html">
            
                
                    <a href="../4.安装 Drill/5.启动 Web 控制台.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>4.5.</b>
                        
                        5.启动 Web 控制台
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5" >
            
            <span><b>5.</b> 5.配置 Drill</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.1" data-path="5.配置 Drill/1.配置介绍.html">
            
                
                    <a href="../5.配置 Drill/1.配置介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.1.</b>
                        
                        1.配置介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.2" data-path="5.配置 Drill/2.配置内存.html">
            
                
                    <a href="../5.配置 Drill/2.配置内存.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.2.</b>
                        
                        2.配置内存
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.3" >
            
            <span><b>5.3.</b> 3.配置一个多租户集群</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.3.1" data-path="5.配置 Drill/3.配置一个多租户集群/1.配置一个多租户介绍.html">
            
                
                    <a href="../5.配置 Drill/3.配置一个多租户集群/1.配置一个多租户介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.3.1.</b>
                        
                        1.配置一个多租户介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.3.2" data-path="5.配置 Drill/3.配置一个多租户集群/2.配置多租户资源.html">
            
                
                    <a href="../5.配置 Drill/3.配置一个多租户集群/2.配置多租户资源.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.3.2.</b>
                        
                        2.配置多租户资源
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.3.3" data-path="5.配置 Drill/3.配置一个多租户集群/3.配置 Drillbit 共享资源.html">
            
                
                    <a href="../5.配置 Drill/3.配置一个多租户集群/3.配置 Drillbit 共享资源.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.3.3.</b>
                        
                        3.配置 Drillbit 共享资源
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.4" data-path="5.配置 Drill/4.配置模拟身份.html">
            
                
                    <a href="../5.配置 Drill/4.配置模拟身份.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.4.</b>
                        
                        4.配置模拟身份
                    </a>
            
            
        </li>
    
        <li class="chapter active" data-level="5.5" data-path="5.配置 Drill/5.配置用户身份验证.html">
            
                
                    <a href="../5.配置 Drill/5.配置用户身份验证.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.5.</b>
                        
                        5.配置用户身份验证
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.6" data-path="5.配置 Drill/6.配置 Hive 用户身份验证.html">
            
                
                    <a href="../5.配置 Drill/6.配置 Hive 用户身份验证.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.6.</b>
                        
                        6.配置 Hive 用户身份验证
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.7" data-path="5.配置 Drill/7.配置 Web 控制台和 REST API 安全.html">
            
                
                    <a href="../5.配置 Drill/7.配置 Web 控制台和 REST API 安全.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.7.</b>
                        
                        7.配置 Web 控制台和 REST API 安全
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.8" >
            
            <span><b>5.8.</b> 8.可选配置</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="5.8.1" data-path="5.配置 Drill/8.可选配置/1.可选配置介绍.html">
            
                
                    <a href="../5.配置 Drill/8.可选配置/1.可选配置介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.8.1.</b>
                        
                        1.可选配置介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.8.2" data-path="5.配置 Drill/8.可选配置/2.启动可选项.html">
            
                
                    <a href="../5.配置 Drill/8.可选配置/2.启动可选项.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.8.2.</b>
                        
                        2.启动可选项
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.8.3" data-path="5.配置 Drill/8.可选配置/3.计划和执行可选项.html">
            
                
                    <a href="../5.配置 Drill/8.可选配置/3.计划和执行可选项.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.8.3.</b>
                        
                        3.计划和执行可选项
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.8.4" data-path="5.配置 Drill/8.可选配置/4.持久化配置存储.html">
            
                
                    <a href="../5.配置 Drill/8.可选配置/4.持久化配置存储.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.8.4.</b>
                        
                        4.持久化配置存储
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="5.9" data-path="5.配置 Drill/9.Drill 端口使用.html">
            
                
                    <a href="../5.配置 Drill/9.Drill 端口使用.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.9.</b>
                        
                        9.Drill 端口使用
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="5.10" data-path="5.配置 Drill/10.配置 Drill 终端.html">
            
                
                    <a href="../5.配置 Drill/10.配置 Drill 终端.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>5.10.</b>
                        
                        10.配置 Drill 终端
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6" >
            
            <span><b>6.</b> 6.连接数据源</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.1" data-path="6.连接数据源/1.介绍.html">
            
                
                    <a href="../6.连接数据源/1.介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.1.</b>
                        
                        1.介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.2" data-path="6.连接数据源/2.注册存储插件.html">
            
                
                    <a href="../6.连接数据源/2.注册存储插件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.2.</b>
                        
                        2.注册存储插件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.3" >
            
            <span><b>6.3.</b> 3.配置存储插件</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="6.3.1" data-path="6.连接数据源/3.配置存储插件/1.插件基础设置.html">
            
                
                    <a href="../6.连接数据源/3.配置存储插件/1.插件基础设置.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.3.1.</b>
                        
                        1.插件基础设置
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.3.2" data-path="6.连接数据源/3.配置存储插件/2.工作区间.html">
            
                
                    <a href="../6.连接数据源/3.配置存储插件/2.工作区间.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.3.2.</b>
                        
                        2.工作区间
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.3.3" data-path="6.连接数据源/3.配置存储插件/3.Drill 默认输出格式.html">
            
                
                    <a href="../6.连接数据源/3.配置存储插件/3.Drill 默认输出格式.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.3.3.</b>
                        
                        3.Drill 默认输出格式
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="6.4" data-path="6.连接数据源/4.文件系统存储插件.html">
            
                
                    <a href="../6.连接数据源/4.文件系统存储插件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.4.</b>
                        
                        4.文件系统存储插件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.5" data-path="6.连接数据源/5.HBase 存储插件.html">
            
                
                    <a href="../6.连接数据源/5.HBase 存储插件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.5.</b>
                        
                        5.HBase 存储插件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.6" data-path="6.连接数据源/6.Hive 存储插件.html">
            
                
                    <a href="../6.连接数据源/6.Hive 存储插件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.6.</b>
                        
                        6.Hive 存储插件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.7" data-path="6.连接数据源/7.RDBMS 存储插件.html">
            
                
                    <a href="../6.连接数据源/7.RDBMS 存储插件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.7.</b>
                        
                        7.RDBMS 存储插件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.8" data-path="6.连接数据源/8.MongoDB 存储插件.html">
            
                
                    <a href="../6.连接数据源/8.MongoDB 存储插件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.8.</b>
                        
                        8.MongoDB 存储插件
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="6.9" data-path="6.连接数据源/9.S3 存储插件.html">
            
                
                    <a href="../6.连接数据源/9.S3 存储插件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>6.9.</b>
                        
                        9.S3 存储插件
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7" >
            
            <span><b>7.</b> 7.ODBC 和 JDBC 接口</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.1" data-path="7.ODBC 和 JDBC 接口/1.介绍.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/1.介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.1.</b>
                        
                        1.介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.2" data-path="7.ODBC 和 JDBC 接口/2.使用 JDBC 驱动.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/2.使用 JDBC 驱动.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.2.</b>
                        
                        2.使用 JDBC 驱动
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.3" data-path="7.ODBC 和 JDBC 接口/3.在 Windows 上使用 JDBC 和 SQuirreL.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/3.在 Windows 上使用 JDBC 和 SQuirreL.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.3.</b>
                        
                        3.在 Windows 上使用 JDBC 和 SQuirreL
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.4" >
            
            <span><b>7.4.</b> 4.安装 ODBC 驱动</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.4.1" data-path="7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/1.在 Linux 上安装驱动.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/1.在 Linux 上安装驱动.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.4.1.</b>
                        
                        1.在 Linux 上安装驱动
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.4.2" data-path="7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/2.在 Mac OS X 上安装驱动.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/2.在 Mac OS X 上安装驱动.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.4.2.</b>
                        
                        2.在 Mac OS X 上安装驱动
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.4.3" data-path="7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/3.在 Windows 上安装驱动.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/3.在 Windows 上安装驱动.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.4.3.</b>
                        
                        3.在 Windows 上安装驱动
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.4.4" data-path="7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/4.在 Windows 上安装 TDC 文件.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/4.安装 ODBC 驱动/4.在 Windows 上安装 TDC 文件.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.4.4.</b>
                        
                        4.在 Windows 上安装 TDC 文件
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.5" >
            
            <span><b>7.5.</b> 5.配置 ODBC</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.5.1" data-path="7.ODBC 和 JDBC 接口/5.配置 ODBC/1.ODBC 配置参考.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/5.配置 ODBC/1.ODBC 配置参考.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.5.1.</b>
                        
                        1.ODBC 配置参考
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.5.2" data-path="7.ODBC 和 JDBC 接口/5.配置 ODBC/2.在 Linux 上配置 ODBC.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/5.配置 ODBC/2.在 Linux 上配置 ODBC.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.5.2.</b>
                        
                        2.在 Linux 上配置 ODBC
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.5.3" data-path="7.ODBC 和 JDBC 接口/5.配置 ODBC/3.在 Max OS X 上配置 ODBC.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/5.配置 ODBC/3.在 Max OS X 上配置 ODBC.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.5.3.</b>
                        
                        3.在 Max OS X 上配置 ODBC
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.5.4" data-path="7.ODBC 和 JDBC 接口/5.配置 ODBC/4.在 Windows 上配置 ODBC.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/5.配置 ODBC/4.在 Windows 上配置 ODBC.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.5.4.</b>
                        
                        4.在 Windows 上配置 ODBC
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.5.5" data-path="7.ODBC 和 JDBC 接口/5.配置 ODBC/5.测试 ODBC 连接.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/5.配置 ODBC/5.测试 ODBC 连接.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.5.5.</b>
                        
                        5.测试 ODBC 连接
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.6" >
            
            <span><b>7.6.</b> 6.使用 Drill</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.6.1" data-path="7.ODBC 和 JDBC 接口/6.使用 Drill/1.介绍.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/6.使用 Drill/1.介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.6.1.</b>
                        
                        1.介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.6.2" data-path="7.ODBC 和 JDBC 接口/6.使用 Drill/2.连接 Drill 到数据源.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/6.使用 Drill/2.连接 Drill 到数据源.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.6.2.</b>
                        
                        2.连接 Drill 到数据源
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.6.3" data-path="7.ODBC 和 JDBC 接口/6.使用 Drill/3.浏览数据和定义视图.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/6.使用 Drill/3.浏览数据和定义视图.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.6.3.</b>
                        
                        3.浏览数据和定义视图
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    
        <li class="chapter " data-level="7.7" >
            
            <span><b>7.7.</b> 7.用 BI 工具连接 Drill</span>
            
            
            <ul class="articles">
                
    
        <li class="chapter " data-level="7.7.1" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/1.介绍.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/1.介绍.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.1.</b>
                        
                        1.介绍
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.7.2" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/2.Tableau 示例.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/2.Tableau 示例.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.2.</b>
                        
                        2.使用 JDBC 驱动
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.7.3" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/3.使用 MicroStrategy 分析.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/3.使用 MicroStrategy 分析.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.3.</b>
                        
                        3.在 Windows 上使用 JDBC 和 SQuirreL
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.7.4" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/4.使用 Tibco Spotfire 客户端.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/4.使用 Tibco Spotfire 客户端.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.4.</b>
                        
                        4.使用 Tibco Spotfire 客户端
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.7.5" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/5.使用 Qlik Sense.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/5.使用 Qlik Sense.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.5.</b>
                        
                        5.使用 Qlik Sense
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.7.6" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/6.使用 Tableau 9 客户端.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/6.使用 Tableau 9 客户端.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.6.</b>
                        
                        6.使用 Tableau 9 客户端
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.7.7" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/7.使用 Tableau 9 服务端.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/7.使用 Tableau 9 服务端.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.7.</b>
                        
                        7.使用 Tableau 9 服务端
                    </a>
            
            
        </li>
    
        <li class="chapter " data-level="7.7.8" data-path="7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/8.配置 JReport.html">
            
                
                    <a href="../7.ODBC 和 JDBC 接口/7.用 BI 工具连接 Drill/8.配置 JReport.html">
                
                        <i class="fa fa-check"></i>
                        
                            <b>7.7.8.</b>
                        
                        8.配置 JReport
                    </a>
            
            
        </li>
    

            </ul>
            
        </li>
    

            </ul>
            
        </li>
    


            
            <li class="divider"></li>
            <li>
                <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
                    本书使用 GitBook 发布
                </a>
            </li>
            
        </ul>
    </nav>
</div>

    <div class="book-body">
        <div class="body-inner">
            <div class="book-header" role="navigation">
    <!-- Actions Left -->
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href="../" >Apache Drill</a>
    </h1>
</div>

            <div class="page-wrapper" tabindex="-1" role="main">
                <div class="page-inner">
                
                
                    <section class="normal" id="section-">
                    
                        <h1 id="&#x914D;&#x7F6E;&#x7528;&#x6237;&#x8EAB;&#x4EFD;&#x9A8C;&#x8BC1;">&#x914D;&#x7F6E;&#x7528;&#x6237;&#x8EAB;&#x4EFD;&#x9A8C;&#x8BC1;</h1>
<p>&#x8BA4;&#x8BC1;&#x662F;&#x4E00;&#x4E2A;&#x7528;&#x6237;&#x5728;&#x7CFB;&#x7EDF;&#x4E0A;&#x8BC6;&#x522B;&#x8EAB;&#x4EFD;&#xFF0C;&#x8BBF;&#x95EE;&#x4E00;&#x4E2A;&#x8FDB;&#x7A0B;&#x7684;&#x8FC7;&#x7A0B;&#x3002;Drill &#x76EE;&#x524D;&#x652F;&#x6301;&#x7528;&#x6237;&#x540D;/&#x5BC6;&#x7801;&#x901A;&#x8FC7; Linux &#x8BA4;&#x8BC1;&#x6A21;&#x5757;&#x6765;&#x8BA4;&#x8BC1;&#xFF08;PAM&#xFF09;&#x3002;&#x8EAB;&#x4EFD;&#x9A8C;&#x8BC1;&#x9009;&#x9879;&#x53EF;&#x4EE5;&#x901A;&#x8FC7; JDBC &#x548C; ODBC &#x63A5;&#x53E3;&#x3002;Linux PAM &#x63D0;&#x4F9B;&#x4E86;&#x8BA4;&#x8BC1;&#x6A21;&#x5757;&#x63A5;&#x53E3;&#xFF0C;&#x6BD4;&#x5982;&#x672C;&#x5730;&#x7684;&#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;&#x7684;&#x5BC6;&#x7801;&#x6587;&#x4EF6;&#x6216;&#x8005; LDAP&#x3002;</p>
<p>&#x5982;&#x679C;&#x7528;&#x4F60;&#x542F;&#x7528;&#x6A21;&#x62DF;&#xFF0C;Drill &#x4EE5;&#x8BA4;&#x8BC1;&#x8EAB;&#x4EFD;&#x6267;&#x884C;&#x5BA2;&#x6237;&#x7AEF;&#x8BF7;&#x6C42;&#x3002;&#x5426;&#x5219;&#xFF0C;Drill &#x4EE5;&#x5F00;&#x59CB;&#x542F;&#x52A8;&#x7684; Drillbit &#x8FDB;&#x7A0B;&#x7684;&#x7528;&#x6237;&#x6765;&#x6267;&#x884C;&#x5BA2;&#x6237;&#x7AEF;&#x8BF7;&#x6C42;&#x3002;&#x4F60;&#x53EF;&#x4EE5;&#x65E2;&#x542F;&#x7528;&#x8BA4;&#x8BC1;&#x53C8;&#x542F;&#x7528;&#x6A21;&#x62DF;&#x6765;&#x63D0;&#x9AD8; Drill &#x5B89;&#x5168;&#x3002;&#x8BE6;&#x60C5;&#x89C1; <a href="4.&#x914D;&#x7F6E;&#x6A21;&#x62DF;&#x8EAB;&#x4EFD;.html">&#x914D;&#x7F6E;&#x6A21;&#x62DF;&#x8EAB;&#x4EFD;</a></p>
<p>&#x5F53;&#x4F7F;&#x7528; PAM &#x6765;&#x8BA4;&#x8BC1;&#xFF0C;&#x6BCF;&#x4E2A;&#x6709;&#x6743;&#x9650;&#x8FD0;&#x884C; Drill &#x67E5;&#x8BE2;&#x7684;&#x7528;&#x6237;&#xFF0C;&#x5FC5;&#x987B;&#x5B58;&#x5728;&#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x7684;&#x7528;&#x6237;&#x6E05;&#x5355;&#x4E2D;&#x3002;&#x7528;&#x6237;&#x540D;&#xFF08;&#x5305;&#x542B; UID&#xFF09;&#x548C;&#x5BC6;&#x7801;&#x5FC5;&#x987B;&#x5728;&#x6240;&#x6709;&#x7684; Drill &#x8282;&#x70B9;&#x4E0A;&#x8BC6;&#x522B;&#x901A;&#x8FC7;&#x3002;</p>
<p>&#x5982;&#x679C;&#x4F7F;&#x7528; PAM &#x5728; /etc/passwd &#x6765;&#x8BA4;&#x8BC1;&#xFF0C;&#x5728;&#x96C6;&#x7FA4;&#x4E2D;&#x6240;&#x6709;&#x7684;&#x8282;&#x70B9;&#x4E0A;&#xFF0C;&#x9A8C;&#x8BC1;&#x7684;&#x7528;&#x6237;&#x6709;&#x6743;&#x9650;&#x542F;&#x52A8; Drill &#x8FDB;&#x7A0B;&#xFF0C;&#x4ED6;&#x4EEC;&#x662F;&#x7528;&#x6237;&#x7EC4;&#x7684;&#x4E00;&#x90E8;&#x5206;&#x3002;&#x4F7F; Drill &#x8BFB;&#x53D6; /etc/shadow &#x6587;&#x4EF6;&#xFF0C;&#x8FDB;&#x884C;&#x8EAB;&#x4EFD;&#x9A8C;&#x8BC1;&#x3002;</p>
<h2 id="&#x7BA1;&#x7406;&#x5458;&#x6743;&#x9650;">&#x7BA1;&#x7406;&#x5458;&#x6743;&#x9650;</h2>
<p>&#x5F53;&#x542F;&#x7528;&#x8EAB;&#x4EFD;&#x8BA4;&#x8BC1;&#xFF0C;&#x4EC5;&#x7BA1;&#x7406;&#x5458;&#x80FD;&#x591F;&#x6267;&#x884C;&#x4EE5;&#x4E0B;&#x4EFB;&#x52A1;&#xFF1A;</p>
<ul>
<li>&#x4F7F;&#x7528; <code>ALTER SYSTEM</code> &#x547D;&#x4EE4;&#x6539;&#x53D8;&#x7CFB;&#x7EDF;&#x7EA7;&#x522B;&#x7684;&#x9009;&#x9879;</li>
<li>&#x901A;&#x8FC7; REST API &#x6216; Web &#x63A7;&#x5236;&#x53F0;&#xFF0C;&#x66F4;&#x65B0;&#x5B58;&#x50A8;&#x63D2;&#x4EF6;&#x914D;&#x7F6E;</li>
<li>&#x5728;&#x5F53;&#x524D;&#x7684;&#x96C6;&#x7FA4;&#x4E0A;&#xFF0C;&#x6D4F;&#x89C8;&#x6240;&#x6709;&#x7528;&#x6237;&#x7684;&#x67E5;&#x8BE2;&#x8BB0;&#x5F55;</li>
<li>&#x5728;&#x96C6;&#x7FA4;&#x4E0A;&#x53D6;&#x6D88;&#x4EFB;&#x4F55;&#x7528;&#x6237;&#x6B63;&#x5728;&#x8FD0;&#x884C;&#x7684;&#x67E5;&#x8BE2;</li>
</ul>
<h2 id="&#x7528;&#x6237;&#x8BA4;&#x8BC1;&#x8FDB;&#x7A0B;">&#x7528;&#x6237;&#x8BA4;&#x8BC1;&#x8FDB;&#x7A0B;</h2>
<p>&#x5F53;&#x7528;&#x6237;&#x8BA4;&#x8BC1;&#x542F;&#x7528;&#xFF0C;&#x6BCF;&#x4E2A;&#x7528;&#x6237;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x5BA2;&#x6237;&#x7AEF;&#x8FDB;&#x5165; Drillbit &#x8FDB;&#x7A0B;&#xFF0C;&#x6BD4;&#x5982; SQLLine&#xFF0C;&#x5FC5;&#x987B;&#x63D0;&#x4F9B;&#x4ED6;&#x4EEC;&#x7684;&#x7528;&#x6237;&#x540D;&#x548C;&#x5BC6;&#x7801;&#x65B9;&#x80FD;&#x8FDB;&#x5165;&#x3002;</p>
<p>&#x4E00;&#x4E2A;&#x7528;&#x6237;&#x5305;&#x542B;&#x4E86; <code>-n</code> &#x548C; <code>-p</code> &#x53C2;&#x6570;&#xFF0C;&#x8FD9;&#x8868;&#x793A;&#x7528;&#x6237;&#x540D;&#x548C;&#x5BC6;&#x7801;&#xFF0C;&#x5F53;&#x6253;&#x5F00; SQLLine &#x65F6;&#xFF0C;&#x4F7F;&#x7528;&#x4EE5;&#x4E0B;&#x793A;&#x4F8B;&#x547D;&#x4EE4;&#xFF1A;</p>
<pre><code class="lang-bash">sqlline &#x2013;u jdbc:drill:zk=<span class="hljs-number">10.10</span>.<span class="hljs-number">11.112</span>:<span class="hljs-number">5181</span> &#x2013;n bob &#x2013;p bobdrill
</code></pre>
<p>&#x53E6;&#x5916;&#xFF0C;&#x4E00;&#x4E2A;&#x7528;&#x6237;&#x767B;&#x5F55;&#x5230; SQLLine&#xFF0C; &#x7136;&#x540E;&#x8F93;&#x5165; <code>!connect</code> &#x547D;&#x4EE4;&#x6765;&#x9690;&#x85CF;&#x5BC6;&#x7801;&#xFF0C;&#x6267;&#x884C;&#x8FC7;&#x7A0B;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A;</p>
<ol>
<li>&#x6253;&#x5F00; SQLLine&#xFF0C;&#x7531; sqline &#x811A;&#x672C;&#x8FD0;&#x884C;&#xFF0C;&#x5728; Linux &#x4E2D;&#xFF0C;&#x793A;&#x4F8B;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A;<pre><code class="lang-bash">bobsmachine:~$ /etc/drill/bin/sqlline
apache drill <span class="hljs-number">1.2</span>.<span class="hljs-number">0</span>
<span class="hljs-string">&quot;a drill in the hand is better than two in the bush&quot;</span>
</code></pre>
</li>
<li>&#x51FA;&#x73B0; sqlline &#x63D0;&#x793A;&#x540E;&#xFF0C;&#x8F93;&#x5165; <code>!connect</code> &#x547D;&#x4EE4;&#xFF0C;&#x50CF; <code>jdbc:drill:zk=zk=&lt;zk name&gt;[:&lt;port&gt;][,&lt;zk name2&gt;[:&lt;port&gt;]... ]</code> &#x8FD9;&#x6837;&#x3002;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A;<pre><code class="lang-bash">sqlline&gt; !connect jdbc:drill:zk=localhost:<span class="hljs-number">2181</span>
scan complete <span class="hljs-keyword">in</span> <span class="hljs-number">1385</span>ms
</code></pre>
</li>
<li>&#x5728;&#x51FA;&#x73B0;&#x7684;&#x63D0;&#x793A;&#x4E2D;&#xFF0C;&#x8F93;&#x5165;&#x7528;&#x6237;&#x540D;&#x548C;&#x5BC6;&#x7801;&#x3002;<pre><code class="lang-bash">Enter username <span class="hljs-keyword">for</span> jdbc:drill:zk=localhost:<span class="hljs-number">2181</span>: bob
Enter password <span class="hljs-keyword">for</span> jdbc:drill:zk=localhost:<span class="hljs-number">2181</span>: *************
</code></pre>
&#x5BC6;&#x7801;&#x4F5C;&#x4E3A;&#x9690;&#x85CF;&#x7C7B;&#x578B;&#x3002;</li>
</ol>
<p>&#x5F53;&#x7528;&#x6237;&#x901A;&#x8FC7; BI &#x5DE5;&#x5177;&#x53D6;&#x8FDE;&#x63A5; Drill&#xFF0C;&#x4F8B;&#x5982; Tableau&#xFF0C;MapR Drill &#x7684; ODBC &#x9A71;&#x52A8;&#x63D0;&#x793A;&#x8F93;&#x5165;&#x7528;&#x6237;&#x540D;&#x548C;&#x5BC6;&#x7801;&#xFF1A;</p>
<p><img src="../res/UserAuth_ODBC_Driver.png" alt="UserAuth_ODBC_Driver.png"></p>
<p>&#x5BA2;&#x6237;&#x7AEF;&#x901A;&#x8FC7;&#x7528;&#x6237;&#x540D;&#x548C;&#x5BC6;&#x7801;&#x5230; Drillbit &#x7684;&#x8FDE;&#x63A5;&#x8BF7;&#x6C42;&#xFF0C;&#x7136;&#x540E;&#x901A;&#x8FC7;&#x51ED;&#x636E; PAM&#x3002;&#x5982;&#x679C; PAM &#x80FD;&#x591F;&#x9A8C;&#x8BC1;&#x901A;&#x8FC7;&#xFF0C;&#x8FDE;&#x63A5;&#x6210;&#x529F;&#xFF0C;&#x7136;&#x540E;&#x80FD;&#x591F;&#x53D1;&#x9001;&#x67E5;&#x8BE2;&#x5230;&#x6587;&#x4EF6;&#x7CFB;&#x7EDF;&#xFF0C;&#x6216;&#x5176;&#x4ED6;&#x5B58;&#x50A8;&#x63D2;&#x4EF6;&#xFF0C;&#x4F8B;&#x5982; Hive &#x6216; HBase&#x3002;&#x53EF;&#x662F;&#xFF0C;&#x5982;&#x679C; PAM &#x4E0D;&#x80FD;&#x9A8C;&#x8BC1;&#x901A;&#x8FC7;&#xFF0C;&#x8FDE;&#x63A5;&#x7EC8;&#x7AEF;&#x51FA;&#x73B0; <code>AUTH_FAILED</code>&#x3002;</p>
<p>&#x4EE5;&#x4E0B;&#x4E3A;&#x7528;&#x6237;&#x5728; Drill &#x4E2D;&#x9A8C;&#x8BC1;&#x7684;&#x6D41;&#x7A0B;&#x56FE;&#xFF1A;</p>
<p><img src="../res/UserAuthProcess.png" alt="UserAuthProcess.png"></p>
<h2 id="&#x5B89;&#x88C5;&#x548C;&#x914D;&#x7F6E;-pam">&#x5B89;&#x88C5;&#x548C;&#x914D;&#x7F6E; PAM</h2>
<p>&#x5B89;&#x88C5;&#x548C;&#x914D;&#x7F6E; Drill PAM&#x3002;Drill &#x8FD9;&#x91CC;&#x4EC5;&#x652F;&#x6301; PAM&#x3002;&#x4EE5;&#x4E0B;&#x4E3A;&#x53EF;&#x9009;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5; <a href="#">&#x7F16;&#x8BD1;&#x548C;&#x5B9E;&#x73B0;&#x901A;&#x7528;&#x7684;&#x8BA4;&#x8BC1;</a>&#x3002;</p>
<pre><code class="lang-bash">&#x63D0;&#x793A;&#xFF1A;&#x4E0D;&#x8981;&#x6307;&#x5411;&#x4E00;&#x4E2A;&#x5DF2;&#x5B58;&#x5728;&#x7684; Hadoop &#x7EC4;&#x4EF6;&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x3002;&#x5176;&#x4ED6;&#x6587;&#x4EF6;&#x7CFB;&#x7EDF;&#x5E93;&#x53EF;&#x80FD;&#x4E0E; Drill &#x5E93;&#x51B2;&#x7A81;&#xFF0C;&#x5BFC;&#x81F4;&#x7CFB;&#x7EDF;&#x9519;&#x8BEF;&#x3002;
</code></pre>
<p>&#x5728; Drill &#x4E2D;&#x901A;&#x8FC7;&#x4EE5;&#x4E0B;&#x6B65;&#x9AA4;&#x6765;&#x5B8C;&#x6210;&#x548C;&#x8BBE;&#x7F6E; PAM&#xFF1A;</p>
<ol>
<li>&#x4E0B;&#x8F7D; <code>tar.gz</code> &#x6587;&#x4EF6;&#x5230; Linux &#x5E73;&#x53F0;&#xFF1A;
<a href="http://sourceforge.net/projects/jpam/files/jpam/jpam-1.1/" target="_blank">http://sourceforge.net/projects/jpam/files/jpam/jpam-1.1/</a></li>
<li>&#x89E3;&#x538B;&#x6587;&#x4EF6;&#xFF0C;&#x7136;&#x540E;&#x62F7;&#x8D1D; <code>libjpam.so</code> &#x6587;&#x4EF6;&#x5230;&#x4E0D;&#x5305;&#x542B;&#x5176;&#x4ED6; Hadoop &#x7EC4;&#x4EF6;&#x7684;&#x6587;&#x4EF6;&#x76EE;&#x5F55;&#x4E2D;&#x3002;
&#x4F8B;&#x5982;&#xFF1A;<code>/opt/pam/</code> &#x76EE;&#x5F55;</li>
<li>&#x589E;&#x52A0;&#x4EE5;&#x4E0B;&#x884C;&#x5230; <code>&lt;DRILL_HOME&gt;/conf/drill-env.sh</code>&#xFF0C;&#x5305;&#x542B; <code>libjpam.so</code> &#x6587;&#x4EF6;&#x7684;&#x5730;&#x65B9;&#xFF1A;
<code>export DRILLBIT_JAVA_OPTS=&quot;-Djava.library.path=&lt;directory&gt;&quot;</code>
&#x4F8B;&#x5982;&#xFF1A;<code>export DRILLBIT_JAVA_OPTS=&quot;-Djava.library.path=/opt/pam/&quot;</code></li>
<li>&#x5728; <code>drill.exec</code> &#x5757;&#x4E2D;&#x589E;&#x52A0;&#x4EE5;&#x4E0B;&#x914D;&#x7F6E;&#x5230; <code>&lt;DRILL_HOME&gt;/conf/drill-override.conf</code>&#xFF1A;<pre><code class="lang-bash">drill.exec {
    security.user.auth {
      enabled: <span class="hljs-literal">true</span>,
      packages += <span class="hljs-string">&quot;org.apache.drill.exec.rpc.user.security&quot;</span>,
      impl: <span class="hljs-string">&quot;pam&quot;</span>,
      pam_profiles: [ <span class="hljs-string">&quot;sudo&quot;</span>, <span class="hljs-string">&quot;login&quot;</span> ]
    }
}
</code></pre>
</li>
<li>&#xFF08;&#x53EF;&#x9009;&#xFF09;&#x589E;&#x52A0;&#x6216;&#x5220;&#x9664;&#x4E0D;&#x540C;&#x7684; PAM &#x914D;&#x7F6E;&#x6587;&#x4EF6;&#xFF0C;&#x6DFB;&#x52A0;&#x6216;&#x5220;&#x9664;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x540D;&#x79F0;&#x4E2D;&#x7684; <code>&#x201C;pam_profiles&#x201D;</code>&#x3002;</li>
<li>&#x5728;&#x6BCF;&#x4E2A; Drill &#x8282;&#x70B9;&#x4E0A;&#x91CD;&#x542F; Drillbit &#x8FDB;&#x7A0B;&#x3002;<pre><code class="lang-bash">&lt;DRILLINSTALL_HOME&gt;/bin/drillbit.sh restart
</code></pre>
</li>
</ol>
<h2 id="&#x5B9E;&#x73B0;&#x548C;&#x914D;&#x7F6E;&#x81EA;&#x5B9A;&#x4E49;&#x9A8C;&#x8BC1;">&#x5B9E;&#x73B0;&#x548C;&#x914D;&#x7F6E;&#x81EA;&#x5B9A;&#x4E49;&#x9A8C;&#x8BC1;</h2>
<p>&#x7BA1;&#x7406;&#x5458;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x63D0;&#x4F9B;&#x7684;&#x6A21;&#x677F;&#x6765;&#x5F00;&#x53D1;&#x548C;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x81EA;&#x5B9A;&#x4E49;&#x7684;&#x57FA;&#x4E8E;&#x7528;&#x6237;&#x540D;/&#x5BC6;&#x7801;&#x7684;&#x8BA4;&#x8BC1;&#x3002;</p>
<p>&#x5B8C;&#x6210;&#x4EE5;&#x4E0B;&#x6B65;&#x9AA4;&#x6765;&#x6784;&#x5EFA;&#x548C;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x81EA;&#x5B9A;&#x4E49;&#x8BA4;&#x8BC1;&#xFF1A;</p>
<ol>
<li><p>&#x6784;&#x5EFA;&#x4EE5;&#x4E0B; Java &#x6587;&#x4EF6;&#xFF1A;</p>
<pre><code class="lang-java">MyCustomDrillUserAuthenticatorImpl.java

<span class="hljs-keyword">package</span> myorg.dept.drill.security;

<span class="hljs-keyword">import</span> org.apache.drill.common.config.DrillConfig;
<span class="hljs-keyword">import</span> org.apache.drill.exec.exception.DrillbitStartupException;

<span class="hljs-keyword">import</span> java.io.IOException;

<span class="hljs-comment">/*
* Implement {@link org.apache.drill.exec.rpc.user.security.UserAuthenticator} for illustraing how to develop a custom authenticator and use it in Drill
*/</span>
<span class="hljs-annotation">@UserAuthenticatorTemplate</span>(type = &#x201C;myCustomAuthenticatorType&#x201D;)
<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MyCustomDrillUserAuthenticatorImpl</span> <span class="hljs-keyword">implements</span> <span class="hljs-title">UserAuthenticator</span> </span>{

 <span class="hljs-keyword">public</span> <span class="hljs-keyword">static</span> <span class="hljs-keyword">final</span> String TEST_USER_1 = <span class="hljs-string">&quot;testUser1&quot;</span>;
 <span class="hljs-keyword">public</span> <span class="hljs-keyword">static</span> <span class="hljs-keyword">final</span> String TEST_USER_2 = <span class="hljs-string">&quot;testUser2&quot;</span>;
 <span class="hljs-keyword">public</span> <span class="hljs-keyword">static</span> <span class="hljs-keyword">final</span> String TEST_USER_1_PASSWORD = <span class="hljs-string">&quot;testUser1Password&quot;</span>;
 <span class="hljs-keyword">public</span> <span class="hljs-keyword">static</span> <span class="hljs-keyword">final</span> String TEST_USER_2_PASSWORD = <span class="hljs-string">&quot;testUser2Password&quot;</span>;

<span class="hljs-comment">/**
* Setup for authenticating user credentials.
*/</span>
 <span class="hljs-annotation">@Override</span>
 <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">setup</span><span class="hljs-params">(DrillConfig drillConfig)</span> <span class="hljs-keyword">throws</span> DrillbitStartupException </span>{
   <span class="hljs-comment">// If the authenticator has any setup such as making sure authenticator provider servers are up and running or</span>
   <span class="hljs-comment">// needed libraries are available, it should be added here.</span>
 }

<span class="hljs-comment">/**
* Authenticate the given &lt;i&gt;user&lt;/i&gt; and &lt;i&gt;password&lt;/i&gt; combination.
*
* <span class="hljs-doctag">@param</span> userName
* <span class="hljs-doctag">@param</span> password
* <span class="hljs-doctag">@throws</span> UserAuthenticationException if authentication fails for given user and password.
*/</span>
 <span class="hljs-annotation">@Override</span>
 <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">authenticate</span><span class="hljs-params">(String userName, String password)</span> <span class="hljs-keyword">throws</span> UserAuthenticationException </span>{

   <span class="hljs-keyword">if</span> (!(TEST_USER_1.equals(user) &amp;&amp; TEST_USER_1_PASSWORD.equals(password)) &amp;&amp;
   !(TEST_USER_2.equals(user) &amp;&amp; TEST_USER_2_PASSWORD.equals(password))) {
     <span class="hljs-keyword">throw</span> <span class="hljs-keyword">new</span> UserAuthenticationException(&#x201C;custom failure message <span class="hljs-keyword">if</span> the admin wants to show it to user&#x201D;);
   }
 }

<span class="hljs-comment">/**
* Close the authenticator. Used to release resources. Ex. LDAP authenticator opens connections to LDAP server,
* such connections resources are released in a safe manner as part of close.
*
* <span class="hljs-doctag">@throws</span> IOException
*/</span>
 <span class="hljs-annotation">@Override</span>
 <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">close</span><span class="hljs-params">()</span> <span class="hljs-keyword">throws</span> IOException </span>{
   <span class="hljs-comment">// Any clean up such as releasing files/network resources should be done here</span>
 }
}
</code></pre>
</li>
<li>&#x6DFB;&#x52A0;&#x6784;&#x5EFA;&#x597D;&#x7684; JAR &#x6587;&#x4EF6;&#x5230;&#x6BCF;&#x4E2A; Drill &#x8282;&#x70B9;&#xFF1A;<pre><code class="lang-bash">&lt;DRILLINSTALL_HOME&gt;/jars
</code></pre>
</li>
<li>&#x5728; <code>&lt;DRILLINSTALL_HOME&gt;/conf/</code> &#x76EE;&#x5F55;&#x4E2D;&#x7684; <code>drill-override.conf</code> &#x6587;&#x4EF6;&#x4E2D;&#xFF0C;&#x6DFB;&#x52A0;&#x4EE5;&#x4E0B;&#x914D;&#x7F6E;&#x5230; <code>drill.exec</code> &#x6A21;&#x5757;&#x4E2D;&#xFF1A;<pre><code class="lang-bash">drill.exec {
 security.user.auth {
     enabled: <span class="hljs-literal">true</span>,
     packages += <span class="hljs-string">&quot;myorg.dept.drill.security&quot;</span>,
     impl: <span class="hljs-string">&quot;myCustomAuthenticatorType&quot;</span>
 }
}
</code></pre>
</li>
<li>&#x5728;&#x6BCF;&#x4E2A; Drill &#x8282;&#x70B9;&#x4E0A;&#x91CD;&#x542F; Drillbit &#x8FDB;&#x7A0B;&#x3002;<pre><code class="lang-bash">&lt;DRILLINSTALL_HOME&gt;/bin/drillbit.sh restart
</code></pre>
</li>
</ol>
<footer class="page-footer"><span class="copyright">Copyright &#xA9; http://drill.smartloli.org 2016 all right reserved&#xFF0C;powered by Gitbook</span><span class="footer-modification">Modify: 
2016-01-15 15:14:04
</span></footer>
                    
                    </section>
                
                
                </div>
            </div>
        </div>

        
        <a href="../5.配置 Drill/4.配置模拟身份.html" class="navigation navigation-prev " aria-label="Previous page: 4.配置模拟身份"><i class="fa fa-angle-left"></i></a>
        
        
        <a href="../5.配置 Drill/6.配置 Hive 用户身份验证.html" class="navigation navigation-next " aria-label="Next page: 6.配置 Hive 用户身份验证"><i class="fa fa-angle-right"></i></a>
        
    </div>
</div>

        
<script src="../gitbook/app.js"></script>

    
    <script src="../gitbook/plugins/gitbook-plugin-baidu/plugin.js"></script>
    

    
    <script src="../gitbook/plugins/gitbook-plugin-sharing/buttons.js"></script>
    

    
    <script src="../gitbook/plugins/gitbook-plugin-fontsettings/buttons.js"></script>
    

    
    <script src="../gitbook/plugins/gitbook-plugin-livereload/plugin.js"></script>
    

<script>
require(["gitbook"], function(gitbook) {
    var config = {"tbfed-pagefooter":{"copyright":"Copyright &copy http://drill.smartloli.org 2016","modify_label":"Modify: ","modify_format":"YYYY-MM-DD HH:mm:ss"},"baidu":{"token":""},"fontsettings":{"size":1,"theme":"white","family":"sans"},"highlight":{},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"livereload":{}};
    gitbook.start(config);
});
</script>

        <script>var _hmt = _hmt || [];(function() {var hm = document.createElement('script');hm.src = '//hm.baidu.com/hm.js?';var s = document.getElementsByTagName('script')[0];s.parentNode.insertBefore(hm, s);})();</script>
    </body>
    
</html>
